//
//  HMSQLiteTools.swift
//  FMDB演练
//
//  Created by 朱建超 on 16/11/29.
//  Copyright © 2016年 itHeiMa. All rights reserved.
//

import UIKit

class HMSQLiteTools: NSObject {

    //使用单例对象
    static let shared : HMSQLiteTools = HMSQLiteTools()
    
    //创建数据库文件，并且打开数据库连接
    //单例对象一旦创建，就打开数据库
    //必须有值
    var queue : FMDatabaseQueue
    
    override init() {
        
        //数据库文件存储在沙河中
        let path = (NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true).last! as NSString).appendingPathComponent("weibo.db")
        //数据库不存在就创建数据库 并且打开连接，如果存在，就直接打开连接
        queue = FMDatabaseQueue(path: path)
        
        print(path)
        
        super.init()
        
        //初始化的时候就创建对应的数据表
        creatTable()
        
    }
    
    //创建数据表
    private func creatTable() {
        
        let sqlite = "CREATE TABLE IF NOT EXISTS T_Status (statusId INTEGER PRIMARY KEY NOT NULL, status TEXT, userId TEXT NOT NULL,create_date TEXT DEFAULT CURRENT_DATE)"
        
        //使用queue数据库操作的核心对象来执行sql语句
        queue.inTransaction { (db, rollback) in
            
            //rollback :如果操作失败就执行回滚的操作
            let result = db?.executeStatements(sqlite)
            
            if result!{
            
                print("数据库创建成功")
            
            }else{
                print("数据库创建失败")
                //执行回滚
                //修改指针的值
                rollback?.pointee = true
            }
        }
        
    }
    
}
